<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>webdoc</title>
    <link rel="stylesheet" type="text/css" href="../static/css/main.css">
</head>
<body>
<div class="nav">
    <div class="logo">
        
            webdoc
        
    </div>
<ul><li><a href="../index.html">0.Async</a></li><li><a href="../html/0.editor.html">0.editor</a></li><li><a href="../html/0.module.html">0.module</a></li><li><a href="../html/1.ES2015.html">1.ES2015</a></li><li><a href="../html/2.Promise.html">2.Promise</a></li><li><a href="../html/3.Node.html">3.Node</a></li><li><a href="../html/4.NodeInstall.html">4.NodeInstall</a></li><li><a href="../html/5.REPL.html">5.REPL</a></li><li><a href="../html/6.NodeCore.html">6.NodeCore</a></li><li><a href="../html/7.module&NPM.html">7.module&NPM</a></li><li><a href="../html/8.Encoding.html">8.Encoding</a></li><li><a href="../html/9.Buffer.html">9.Buffer</a></li><li><a href="../html/10.fs.html">10.fs</a></li><li><a href="../html/11.Stream-1.html">11.Stream-1</a></li><li><a href="../html/11.Stream-2.html">11.Stream-2</a></li><li><a href="../html/11.Stream-3.html">11.Stream-3</a></li><li><a href="../html/11.Stream-4.html">11.Stream-4</a></li><li class="active"><a href="../html/12-Network-2.html">12-Network-2</a></li><li><a href="../html/12.NetWork-3.html">12.NetWork-3</a></li><li><a href="../html/12.Network-1.html">12.Network-1</a></li><li><a href="../html/13.tcp.html">13.tcp</a></li><li><a href="../html/14.http-1.html">14.http-1</a></li><li><a href="../html/14.http-2.html">14.http-2</a></li><li><a href="../html/15.compress.html">15.compress</a></li><li><a href="../html/16.crypto.html">16.crypto</a></li><li><a href="../html/17.process.html">17.process</a></li><li><a href="../html/18.yargs.html">18.yargs</a></li><li><a href="../html/19.cache.html">19.cache</a></li><li><a href="../html/20.action.html">20.action</a></li><li><a href="../html/21.https.html">21.https</a></li><li><a href="../html/22.cookie.html">22.cookie</a></li><li><a href="../html/23.session.html">23.session</a></li><li><a href="../html/24.express-1.html">24.express-1</a></li><li><a href="../html/24.express-2.html">24.express-2</a></li><li><a href="../html/24.express-3.html">24.express-3</a></li><li><a href="../html/24.express-4.html">24.express-4</a></li><li><a href="../html/25.koa-1.html">25.koa-1</a></li><li><a href="../html/26.webpack-1-basic.html">26.webpack-1-basic</a></li><li><a href="../html/26.webpack-2-optimize.html">26.webpack-2-optimize</a></li><li><a href="../html/26.webpack-3.tapable.html">26.webpack-3.tapable</a></li><li><a href="../html/26.webpack-4-AST.html">26.webpack-4-AST</a></li><li><a href="../html/26.webpack-5-source.html">26.webpack-5-source</a></li><li><a href="../html/26.webpack-6-loader.html">26.webpack-6-loader</a></li><li><a href="../html/26.webpack-7-plugin.html">26.webpack-7-plugin</a></li><li><a href="../html/26.webpack-8-hand.html">26.webpack-8-hand</a></li><li><a href="../html/27.react-1.html">27.react-1</a></li><li><a href="../html/27.react-2.html">27.react-2</a></li><li><a href="../html/27.react-3.html">27.react-3</a></li><li><a href="../html/27.react-4-immutable.html">27.react-4-immutable</a></li><li><a href="../html/27.react-5-react-dom-diff.html">27.react-5-react-dom-diff</a></li><li><a href="../html/27.react-6.html">27.react-6</a></li><li><a href="../html/28.react-mobx.html">28.react-mobx</a></li><li><a href="../html/28.redux-0.html">28.redux-0</a></li><li><a href="../html/28.redux-1.html">28.redux-1</a></li><li><a href="../html/28.redux-2-中间件.html">28.redux-2-中间件</a></li><li><a href="../html/28.redux-3-saga.html">28.redux-3-saga</a></li><li><a href="../html/28.redux-jwt-back.html">28.redux-jwt-back</a></li><li><a href="../html/28.redux-jwt-front.html">28.redux-jwt-front</a></li><li><a href="../html/29.mongodb-1.html">29.mongodb-1</a></li><li><a href="../html/29.mongodb-2.html">29.mongodb-2</a></li><li><a href="../html/29.mongodb-3.html">29.mongodb-3</a></li><li><a href="../html/29.mongodb-4.html">29.mongodb-4</a></li><li><a href="../html/29.mongodb-5.html">29.mongodb-5</a></li><li><a href="../html/29.mongodb-6.html">29.mongodb-6</a></li><li><a href="../html/30.cms-1-mysql.html">30.cms-1-mysql</a></li><li><a href="../html/30.cms-2-mysql.html">30.cms-2-mysql</a></li><li><a href="../html/30.cms-3-mysql.html">30.cms-3-mysql</a></li><li><a href="../html/30.cms-4-egg.html">30.cms-4-egg</a></li><li><a href="../html/30.cms-5-api.html">30.cms-5-api</a></li><li><a href="../html/30.cms-6-roadhog.html">30.cms-6-roadhog</a></li><li><a href="../html/30.cms-7-umi.html">30.cms-7-umi</a></li><li><a href="../html/30.cms-8-dva.html">30.cms-8-dva</a></li><li><a href="../html/30.cms-9-dva.html">30.cms-9-dva</a></li><li><a href="../html/30.cms-10-dva.html">30.cms-10-dva</a></li><li><a href="../html/30.cms-11-front.html">30.cms-11-front</a></li><li><a href="../html/31.cms-12-api.html">31.cms-12-api</a></li><li><a href="../html/31.cms-13-front.html">31.cms-13-front</a></li><li><a href="../html/31.cms-14-deploy.html">31.cms-14-deploy</a></li><li><a href="../html/32.ant.html">32.ant</a></li><li><a href="../html/33.redis.html">33.redis</a></li><li><a href="../html/34.unittest.html">34.unittest</a></li><li><a href="../html/35.jwt.html">35.jwt</a></li><li><a href="../html/36.websocket-1.html">36.websocket-1</a></li><li><a href="../html/36.websocket-2.html">36.websocket-2</a></li><li><a href="../html/38.chat-api-1.html">38.chat-api-1</a></li><li><a href="../html/38.chat-api-2.html">38.chat-api-2</a></li><li><a href="../html/38.chat-3.html">38.chat-3</a></li><li><a href="../html/38.chat-api-3.html">38.chat-api-3</a></li><li><a href="../html/38.chat.html">38.chat</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/39.crawl-0.html">39.crawl-0</a></li><li><a href="../html/39.crawl-1.html">39.crawl-1</a></li><li><a href="../html/39.crawl-2.html">39.crawl-2</a></li><li><a href="../html/40.deploy.html">40.deploy</a></li><li><a href="../html/41.safe.html">41.safe</a></li><li><a href="../html/42.test.html">42.test</a></li><li><a href="../html/43.nginx.html">43.nginx</a></li><li><a href="../html/44.enzyme.html">44.enzyme</a></li><li><a href="../html/45.docker.html">45.docker</a></li><li><a href="../html/46.elastic.html">46.elastic</a></li><li><a href="../html/47.oauth.html">47.oauth</a></li><li><a href="../html/48.wxpay.html">48.wxpay</a></li><li><a href="../html/49.nunjucks.html">49.nunjucks</a></li><li><a href="../html/50.ketang.html">50.ketang</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/51.typescript.html">51.typescript</a></li><li><a href="../html/52.UML.html">52.UML</a></li><li><a href="../html/53.design.html">53.design</a></li><li><a href="../html/index.html">index</a></li></ul></div>


<div class="warpper">

    <div class="page-toc">
        <ul><li><a href="#t01. OSI七层网络模型">1. OSI七层网络模型</a></li><li><a href="#t12.TCP/IP 参考模型">2.TCP/IP 参考模型</a></li><li><a href="#t23. 传输层">3. 传输层</a></li><li><a href="#t34. TCP格式">4. TCP格式</a></li><li><a href="#t45. 三次握手">5. 三次握手</a></li><li><a href="#t56. 数据传输">6. 数据传输</a></li><li><a href="#t67. 四次挥手">7. 四次挥手</a></li><li><a href="#t78. 问题">8. 问题</a></li><li><a href="#t89.同学们的文章">9.同学们的文章</a></li></ul>
    </div>
    
    <div class="content markdown-body">
        <h2 id="t01. OSI&#x4E03;&#x5C42;&#x7F51;&#x7EDC;&#x6A21;&#x578B;">1. OSI&#x4E03;&#x5C42;&#x7F51;&#x7EDC;&#x6A21;&#x578B; <a href="#t01. OSI&#x4E03;&#x5C42;&#x7F51;&#x7EDC;&#x6A21;&#x578B;"> # </a></h2>
<p>OSI&#x662F;Open System Interconnection&#x7684;&#x7F29;&#x5199;&#xFF0C;&#x610F;&#x4E3A;&#x5F00;&#x653E;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E92;&#x8054;&#x3002;&#x56FD;&#x9645;&#x6807;&#x51C6;&#x5316;&#x7EC4;&#x7EC7;&#xFF08;ISO&#xFF09;&#x5236;&#x5B9A;&#x4E86;OSI&#x6A21;&#x578B;&#xFF0C;&#x8BE5;&#x6A21;&#x578B;&#x5B9A;&#x4E49;&#x4E86;&#x4E0D;&#x540C;&#x8BA1;&#x7B97;&#x673A;&#x4E92;&#x8054;&#x7684;&#x6807;&#x51C6;&#xFF0C;&#x662F;&#x8BBE;&#x8BA1;&#x548C;&#x63CF;&#x8FF0;&#x8BA1;&#x7B97;&#x673A;&#x7F51;&#x7EDC;&#x901A;&#x4FE1;&#x7684;&#x57FA;&#x672C;&#x6846;&#x67B6;&#x3002;OSI&#x6A21;&#x578B;&#x628A;&#x7F51;&#x7EDC;&#x901A;&#x4FE1;&#x7684;&#x5DE5;&#x4F5C;&#x5206;&#x4E3A;7&#x5C42;&#xFF0C;&#x5206;&#x522B;&#x662F;&#x7269;&#x7406;&#x5C42;&#x3001;&#x6570;&#x636E;&#x94FE;&#x8DEF;&#x5C42;&#x3001;&#x7F51;&#x7EDC;&#x5C42;&#x3001;&#x4F20;&#x8F93;&#x5C42;&#x3001;&#x4F1A;&#x8BDD;&#x5C42;&#x3001;&#x8868;&#x793A;&#x5C42;&#x548C;&#x5E94;&#x7528;&#x5C42;&#x3002;
&#x9996;&#x5148;&#x6765;&#x770B;&#x770B;OSI&#x7684;&#x4E03;&#x5C42;&#x6A21;&#x578B;:</p>
<p><img src="http://img.zhufengpeixun.cn/osi7cen.png" alt="sevenlayer"></p>
<h2 id="t12.TCP/IP &#x53C2;&#x8003;&#x6A21;&#x578B;">2.TCP/IP &#x53C2;&#x8003;&#x6A21;&#x578B; <a href="#t12.TCP/IP &#x53C2;&#x8003;&#x6A21;&#x578B;"> # </a></h2>
<p>TCP/IP&#x662F;&#x4F20;&#x8F93;&#x63A7;&#x5236;&#x534F;&#x8BAE;/&#x7F51;&#x7EDC;&#x4E92;&#x8054;&#x534F;&#x8BAE;&#x7684;&#x7B80;&#x79F0;&#x3002;&#x65E9;&#x671F;&#x7684;TCP/IP&#x6A21;&#x578B;&#x662F;&#x4E00;&#x4E2A;&#x56DB;&#x5C42;&#x7ED3;&#x6784;&#xFF0C;&#x4ECE;&#x4E0B;&#x5F80;&#x4E0A;&#x4F9D;&#x6B21;&#x662F;&#x7F51;&#x7EDC;&#x63A5;&#x53E3;&#x5C42;&#x3001;&#x4E92;&#x8054;&#x7F51;&#x5C42;&#x3001;&#x4F20;&#x8F93;&#x5C42;&#x548C;&#x5E94;&#x7528;&#x5C42;&#x3002;&#x540E;&#x6765;&#x5728;&#x4F7F;&#x7528;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;&#x501F;&#x9274;OSI&#x4E03;&#x5C42;&#x53C2;&#x8003;&#x6A21;&#x578B;&#xFF0C;&#x5C06;&#x7F51;&#x7EDC;&#x63A5;&#x53E3;&#x5C42;&#x5212;&#x5206;&#x4E3A;&#x4E86;&#x7269;&#x7406;&#x5C42;&#x548C;&#x6570;&#x636E;&#x94FE;&#x8DEF;&#x5C42;&#xFF0C;&#x5F62;&#x6210;&#x4E94;&#x5C42;&#x7ED3;&#x6784;&#x3002;</p>
<p><img src="http://img.zhufengpeixun.cn/tcpip5.png" alt="fivelayer"></p>
<h2 id="t23. &#x4F20;&#x8F93;&#x5C42;">3. &#x4F20;&#x8F93;&#x5C42; <a href="#t23. &#x4F20;&#x8F93;&#x5C42;"> # </a></h2>
<p>&#x4F20;&#x8F93;&#x5C42;&#x662F;&#x9762;&#x5411;&#x8FDE;&#x63A5;&#x7684;&#x3001;&#x53EF;&#x9760;&#x7684;&#x7684;&#x8FDB;&#x7A0B;&#x5230;&#x8FDB;&#x7A0B;&#x901A;&#x4FE1;&#x7684;&#x534F;&#x8BAE;&#x3002;TCP&#x63D0;&#x4F9B;&#x5168;&#x53CC;&#x5DE5;&#x670D;&#x52A1;&#xFF0C;&#x5373;&#x6570;&#x636E;&#x53EF;&#x5728;&#x540C;&#x4E00;&#x65F6;&#x95F4;&#x53CC;&#x5411;&#x4F20;&#x64AD;&#x3002;TCP&#x5C06;&#x82E5;&#x5E72;&#x4E2A;&#x5B57;&#x8282;&#x6784;&#x6210;&#x4E00;&#x4E2A;&#x5206;&#x7EC4;&#xFF0C;&#x6B64;&#x5206;&#x7EC4;&#x79F0;&#x4E3A;&#x62A5;&#x6587;&#x6BB5;(Segment)&#x3002;&#x63D0;&#x4F9B;&#x4E86;&#x4E00;&#x79CD;&#x7AEF;&#x5230;&#x7AEF;&#x7684;&#x8FDE;&#x63A5;&#x3002;
&#x4F20;&#x8F93;&#x5C42;&#x7684;&#x534F;&#x8BAE;&#x4E3B;&#x8981;&#x662F;TCP &#xFF0C;TCP(Transimision Control Protocal)&#x662F;&#x4E00;&#x79CD;&#x53EF;&#x9760;&#x7684;&#x3001;&#x9762;&#x5411;&#x8FDE;&#x63A5;&#x7684;&#x534F;&#x8BAE;&#xFF0C;&#x4F20;&#x8F93;&#x6548;&#x7387;&#x4F4E;&#x3002;</p>
<h2 id="t34. TCP&#x683C;&#x5F0F;">4. TCP&#x683C;&#x5F0F; <a href="#t34. TCP&#x683C;&#x5F0F;"> # </a></h2>
<p><img src="http://img.zhufengpeixun.cn/tcpconstructor.jpg" alt="tcpframe"></p>
<ul>
<li>&#x6E90;&#x7AEF;&#x53E3;&#x53F7;&#x548C;&#x76EE;&#x6807;&#x7AEF;&#x53E3;&#x53F7;&#xFF0C;&#x8BA1;&#x7B97;&#x673A;&#x901A;&#x8FC7;&#x7AEF;&#x53E3;&#x53F7;&#x8BC6;&#x522B;&#x8BBF;&#x95EE;&#x54EA;&#x4E2A;&#x670D;&#x52A1;,&#x6BD4;&#x5982;http&#x670D;&#x52A1;&#x6216;ftp&#x670D;&#x52A1;&#xFF0C;&#x53D1;&#x9001;&#x65B9;&#x7AEF;&#x53E3;&#x53F7;&#x662F;&#x8FDB;&#x884C;&#x968F;&#x673A;&#x7AEF;&#x53E3;&#xFF0C;&#x76EE;&#x6807;&#x7AEF;&#x53E3;&#x53F7;&#x51B3;&#x5B9A;&#x4E86;&#x63A5;&#x6536;&#x65B9;&#x54EA;&#x4E2A;&#x7A0B;&#x5E8F;&#x6765;&#x63A5;&#x6536;</li>
<li>32&#x4F4D;&#x5E8F;&#x5217;&#x53F7; TCP&#x7528;&#x5E8F;&#x5217;&#x53F7;&#x5BF9;&#x6570;&#x636E;&#x5305;&#x8FDB;&#x884C;&#x6807;&#x8BB0;&#xFF0C;&#x4EE5;&#x4FBF;&#x5728;&#x5230;&#x8FBE;&#x76EE;&#x7684;&#x5730;&#x540E;&#x91CD;&#x65B0;&#x91CD;&#x88C5;&#xFF0C;&#x5047;&#x8BBE;&#x5F53;&#x524D;&#x7684;&#x5E8F;&#x5217;&#x53F7;&#x4E3A; s&#xFF0C;&#x53D1;&#x9001;&#x6570;&#x636E;&#x957F;&#x5EA6;&#x4E3A; l&#xFF0C;&#x5219;&#x4E0B;&#x6B21;&#x53D1;&#x9001;&#x6570;&#x636E;&#x65F6;&#x7684;&#x5E8F;&#x5217;&#x53F7;&#x4E3A; s + l&#x3002;&#x5728;&#x5EFA;&#x7ACB;&#x8FDE;&#x63A5;&#x65F6;&#x901A;&#x5E38;&#x7531;&#x8BA1;&#x7B97;&#x673A;&#x751F;&#x6210;&#x4E00;&#x4E2A;&#x968F;&#x673A;&#x6570;&#x4F5C;&#x4E3A;&#x5E8F;&#x5217;&#x53F7;&#x7684;&#x521D;&#x59CB;&#x503C;</li>
<li>&#x786E;&#x8BA4;&#x5E94;&#x7B54;&#x53F7; &#x5B83;&#x7B49;&#x4E8E;&#x4E0B;&#x4E00;&#x6B21;&#x5E94;&#x8BE5;&#x63A5;&#x6536;&#x5230;&#x7684;&#x6570;&#x636E;&#x7684;&#x5E8F;&#x5217;&#x53F7;&#x3002;&#x5047;&#x8BBE;&#x53D1;&#x9001;&#x7AEF;&#x7684;&#x5E8F;&#x5217;&#x53F7;&#x4E3A; s&#xFF0C;&#x53D1;&#x9001;&#x6570;&#x636E;&#x7684;&#x957F;&#x5EA6;&#x4E3A; l&#xFF0C;&#x90A3;&#x4E48;&#x63A5;&#x6536;&#x7AEF;&#x8FD4;&#x56DE;&#x7684;&#x786E;&#x8BA4;&#x5E94;&#x7B54;&#x53F7;&#x4E5F;&#x662F; s + l&#x3002;&#x53D1;&#x9001;&#x7AEF;&#x63A5;&#x6536;&#x5230;&#x8FD9;&#x4E2A;&#x786E;&#x8BA4;&#x5E94;&#x7B54;&#x540E;&#xFF0C;&#x53EF;&#x4EE5;&#x8BA4;&#x4E3A;&#x8FD9;&#x4E2A;&#x4F4D;&#x7F6E;&#x4EE5;&#x524D;&#x6240;&#x6709;&#x7684;&#x6570;&#x636E;&#x90FD;&#x5DF2;&#x88AB;&#x6B63;&#x5E38;&#x63A5;&#x6536;&#x3002;</li>
<li>&#x9996;&#x90E8;&#x957F;&#x5EA6;&#xFF1A;TCP &#x9996;&#x90E8;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x5355;&#x4F4D;&#x4E3A; 4 &#x5B57;&#x8282;&#x3002;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x53EF;&#x9009;&#x5B57;&#x6BB5;&#xFF0C;&#x90A3;&#x4E48;&#x8FD9;&#x91CC;&#x7684;&#x503C;&#x5C31;&#x662F; 5&#x3002;&#x8868;&#x793A; TCP &#x9996;&#x90E8;&#x7684;&#x957F;&#x5EA6;&#x4E3A; 20 &#x5B57;&#x8282;&#x3002;</li>
<li>&#x63A7;&#x5236;&#x4F4D; TCP&#x7684;&#x8FDE;&#x63A5;&#x3001;&#x4F20;&#x8F93;&#x548C;&#x65AD;&#x5F00;&#x90FD;&#x53D7;&#x8FD9;&#x516D;&#x4E2A;&#x63A7;&#x5236;&#x4F4D;&#x7684;&#x6307;&#x6325;<ul>
<li>PSH(push&#x6025;&#x8FEB;&#x4F4D;) &#x7F13;&#x5B58;&#x533A;&#x5C06;&#x6EE1;&#xFF0C;&#x7ACB;&#x523B;&#x4F20;&#x8F93;&#x901F;&#x5EA6;</li>
<li>RST(reset&#x91CD;&#x7F6E;&#x4F4D;) &#x8FDE;&#x63A5;&#x65AD;&#x4E86;&#x91CD;&#x65B0;&#x8FDE;&#x63A5;</li>
<li>URG(urgent&#x7D27;&#x6025;&#x4F4D;) &#x7D27;&#x6025;&#x4FE1;&#x53F7;</li>
<li>ACK(acknowledgement &#x786E;&#x8BA4;)&#x4E3A;1&#x8868;&#x793A;&#x786E;&#x8BA4;&#x53F7;</li>
<li>SYN(synchronous&#x5EFA;&#x7ACB;&#x8054;&#x673A;) &#x540C;&#x6B65;&#x5E8F;&#x53F7;&#x4F4D; TCP&#x5EFA;&#x7ACB;&#x8FDE;&#x63A5;&#x65F6;&#x8981;&#x5C06;&#x8FD9;&#x4E2A;&#x503C;&#x8BBE;&#x4E3A;1</li>
<li>FIN&#x53D1;&#x9001;&#x7AEF;&#x5B8C;&#x6210;&#x4F4D;&#xFF0C;&#x63D0;&#x51FA;&#x65AD;&#x5F00;&#x8FDE;&#x63A5;&#x7684;&#x4E00;&#x65B9;&#x628A;FIN&#x7F6E;&#x4E3A;1&#x8868;&#x793A;&#x8981;&#x65AD;&#x5F00;&#x8FDE;&#x63A5;</li>
</ul>
</li>
<li>&#x7A97;&#x53E3;&#x503C; &#x8BF4;&#x660E;&#x672C;&#x5730;&#x53EF;&#x63A5;&#x6536;&#x6570;&#x636E;&#x6BB5;&#x7684;&#x6570;&#x76EE;&#xFF0C;&#x8FD9;&#x4E2A;&#x503C;&#x7684;&#x5927;&#x5C0F;&#x662F;&#x53EF;&#x53D8;&#x7684;&#x3002;&#x5F53;&#x7F51;&#x7EDC;&#x901A;&#x7545;&#x65F6;&#x5C06;&#x8FD9;&#x4E2A;&#x7A97;&#x53E3;&#x503C;&#x53D8;&#x5927;&#x52A0;&#x5FEB;&#x4F20;&#x8F93;&#x901F;&#x5EA6;&#xFF0C;&#x5F53;&#x7F51;&#x7EDC;&#x4E0D;&#x7A33;&#x5B9A;&#x65F6;&#x51CF;&#x5C11;&#x8FD9;&#x4E2A;&#x503C;&#x53EF;&#x4EE5;&#x4FDD;&#x8BC1;&#x7F51;&#x7EDC;&#x6570;&#x636E;&#x7684;&#x53EF;&#x9760;&#x4F20;&#x8F93;&#x3002;&#x5B83;&#x662F;&#x6765;&#x5728;TCP&#x4F20;&#x8F93;&#x4E2D;&#x8FDB;&#x884C;&#x6D41;&#x91CF;&#x63A7;&#x5236;&#x7684;</li>
<li>&#x7A97;&#x53E3;&#x5927;&#x5C0F;&#xFF1A;&#x7528;&#x4E8E;&#x8868;&#x793A;&#x4ECE;&#x5E94;&#x7B54;&#x53F7;&#x5F00;&#x59CB;&#x80FD;&#x591F;&#x63A5;&#x53D7;&#x591A;&#x5C11;&#x4E2A; 8 &#x4F4D;&#x5B57;&#x8282;&#x3002;&#x5982;&#x679C;&#x7A97;&#x53E3;&#x5927;&#x5C0F;&#x4E3A; 0&#xFF0C;&#x53EF;&#x4EE5;&#x53D1;&#x9001;&#x7A97;&#x53E3;&#x63A2;&#x6D4B;&#x3002;</li>
<li>&#x6548;&#x9A8C;&#x548C;: &#x7528;&#x6765;&#x505A;&#x5DEE;&#x9519;&#x63A7;&#x5236;&#xFF0C;TCP&#x6821;&#x9A8C;&#x548C;&#x7684;&#x8BA1;&#x7B97;&#x5305;&#x62EC;TCP&#x9996;&#x90E8;&#x3001;&#x6570;&#x636E;&#x548C;&#x5176;&#x5B83;&#x586B;&#x5145;&#x5B57;&#x8282;&#x3002;&#x5728;&#x53D1;&#x9001;TCP&#x6570;&#x636E;&#x6BB5;&#x65F6;&#xFF0C;&#x7531;&#x53D1;&#x9001;&#x7AEF;&#x8BA1;&#x7B97;&#x6821;&#x9A8C;&#x548C;&#xFF0C;&#x5F53;&#x5230;&#x8FBE;&#x76EE;&#x7684;&#x5730;&#x65F6;&#x53C8;&#x8FDB;&#x884C;&#x4E00;&#x6B21;&#x68C0;&#x9A8C;&#x548C;&#x8BA1;&#x7B97;&#x3002;&#x5982;&#x679C;&#x4E24;&#x6B21;&#x6821;&#x9A8C; &#x548C;&#x4E00;&#x81F4;&#x8BF4;&#x660E;&#x6570;&#x636E;&#x662F;&#x6B63;&#x786E;&#x7684;&#xFF0C;&#x5426;&#x5219; &#x5C06;&#x8BA4;&#x4E3A;&#x6570;&#x636E;&#x88AB;&#x7834;&#x574F;&#xFF0C;&#x63A5;&#x6536;&#x7AEF;&#x5C06;&#x4E22;&#x5F03;&#x8BE5;&#x6570;&#x636E;</li>
<li>&#x7D27;&#x6025;&#x6307;&#x9488;&#xFF1A;&#x5C3D;&#x5728; URG(urgent&#x7D27;&#x6025;) &#x63A7;&#x5236;&#x4F4D;&#x4E3A; 1 &#x65F6;&#x6709;&#x6548;&#x3002;&#x8868;&#x793A;&#x7D27;&#x6025;&#x6570;&#x636E;&#x7684;&#x672B;&#x5C3E;&#x5728; TCP &#x6570;&#x636E;&#x90E8;&#x5206;&#x4E2D;&#x7684;&#x4F4D;&#x7F6E;&#x3002;&#x901A;&#x5E38;&#x5728;&#x6682;&#x65F6;&#x4E2D;&#x65AD;&#x901A;&#x4FE1;&#x65F6;&#x4F7F;&#x7528;&#xFF08;&#x6BD4;&#x5982;&#x8F93;&#x5165; Ctrl + C&#xFF09;&#x3002;</li>
</ul>
<h2 id="t45. &#x4E09;&#x6B21;&#x63E1;&#x624B;">5. &#x4E09;&#x6B21;&#x63E1;&#x624B; <a href="#t45. &#x4E09;&#x6B21;&#x63E1;&#x624B;"> # </a></h2>
<p>TCP&#x662F;&#x9762;&#x5411;&#x8FDE;&#x63A5;&#x7684;&#xFF0C;&#x65E0;&#x8BBA;&#x54EA;&#x4E00;&#x65B9;&#x5411;&#x53E6;&#x4E00;&#x65B9;&#x53D1;&#x9001;&#x6570;&#x636E;&#x4E4B;&#x524D;&#xFF0C;&#x90FD;&#x5FC5;&#x987B;&#x5148;&#x5728;&#x53CC;&#x65B9;&#x4E4B;&#x95F4;&#x5EFA;&#x7ACB;&#x4E00;&#x6761;&#x8FDE;&#x63A5;&#x3002;&#x5728;TCP/IP&#x534F;&#x8BAE;&#x4E2D;&#xFF0C;TCP &#x534F;&#x8BAE;&#x63D0;&#x4F9B;&#x53EF;&#x9760;&#x7684;&#x8FDE;&#x63A5;&#x670D;&#x52A1;&#xFF0C;&#x8FDE;&#x63A5;&#x662F;&#x901A;&#x8FC7;&#x4E09;&#x6B21;&#x63E1;&#x624B;&#x8FDB;&#x884C;&#x521D;&#x59CB;&#x5316;&#x7684;&#x3002;&#x4E09;&#x6B21;&#x63E1;&#x624B;&#x7684;&#x76EE;&#x7684;&#x662F;&#x540C;&#x6B65;&#x8FDE;&#x63A5;&#x53CC;&#x65B9;&#x7684;&#x5E8F;&#x5217;&#x53F7;&#x548C;&#x786E;&#x8BA4;&#x53F7; &#x5E76;&#x4EA4;&#x6362; TCP&#x7A97;&#x53E3;&#x5927;&#x5C0F;&#x4FE1;&#x606F;&#x3002;
<img src="http://img.zhufengpeixun.cn/shake8.jpg" alt="handshake2"></p>
<p>&#x4E3A;&#x4E86;&#x65B9;&#x4FBF;&#x63CF;&#x8FF0;&#x6211;&#x4EEC;&#x5C06;&#x4E3B;&#x52A8;&#x53D1;&#x8D77;&#x8BF7;&#x6C42;&#x7684;172.16.17.94:8080 &#x4E3B;&#x673A;&#x79F0;&#x4E3A;&#x5BA2;&#x6237;&#x7AEF;&#xFF0C;&#x5C06;&#x8FD4;&#x56DE;&#x6570;&#x636E;&#x7684;&#x4E3B;&#x673A;172.16.17.94:8080&#x79F0;&#x4E3A;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x4EE5;&#x4E0B;&#x4E5F;&#x662F;&#x3002;</p>
<ul>
<li>&#x7B2C;&#x4E00;&#x6B21;&#x63E1;&#x624B;: &#x5EFA;&#x7ACB;&#x8FDE;&#x63A5;&#x3002;&#x5BA2;&#x6237;&#x7AEF;&#x53D1;&#x9001;&#x8FDE;&#x63A5;&#x8BF7;&#x6C42;&#xFF0C;&#x53D1;&#x9001;SYN&#x62A5;&#x6587;&#xFF0C;&#x5C06;seq&#x8BBE;&#x7F6E;&#x4E3A;0&#x3002;&#x7136;&#x540E;&#xFF0C;&#x5BA2;&#x6237;&#x7AEF;&#x8FDB;&#x5165;SYN_SEND&#x72B6;&#x6001;&#xFF0C;&#x7B49;&#x5F85;&#x670D;&#x52A1;&#x5668;&#x7684;&#x786E;&#x8BA4;&#x3002;</li>
<li>&#x7B2C;&#x4E8C;&#x6B21;&#x63E1;&#x624B;: &#x670D;&#x52A1;&#x5668;&#x6536;&#x5230;&#x5BA2;&#x6237;&#x7AEF;&#x7684;SYN&#x62A5;&#x6587;&#x6BB5;&#x3002;&#x9700;&#x8981;&#x5BF9;&#x8FD9;&#x4E2A;SYN&#x62A5;&#x6587;&#x6BB5;&#x8FDB;&#x884C;&#x786E;&#x8BA4;&#xFF0C;&#x53D1;&#x9001;ACK&#x62A5;&#x6587;&#xFF0C;&#x5C06;ack&#x8BBE;&#x7F6E;&#x4E3A;1&#x3002;&#x540C;&#x65F6;&#xFF0C;&#x81EA;&#x5DF1;&#x8FD8;&#x8981;&#x53D1;&#x9001;SYN&#x8BF7;&#x6C42;&#x4FE1;&#x606F;&#xFF0C;&#x5C06;seq&#x4E3A;0&#x3002;&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x5C06;&#x4E0A;&#x8FF0;&#x6240;&#x6709;&#x4FE1;&#x606F;&#x4E00;&#x5E76;&#x53D1;&#x9001;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#xFF0C;&#x6B64;&#x65F6;&#x670D;&#x52A1;&#x5668;&#x8FDB;&#x5165;SYN_RECV&#x72B6;&#x6001;&#x3002;</li>
<li>&#x7B2C;&#x4E09;&#x6B21;&#x63E1;&#x624B;: &#x5BA2;&#x6237;&#x7AEF;&#x6536;&#x5230;&#x670D;&#x52A1;&#x5668;&#x7684;ACK&#x548C;SYN&#x62A5;&#x6587;&#x540E;&#xFF0C;&#x8FDB;&#x884C;&#x786E;&#x8BA4;&#xFF0C;&#x7136;&#x540E;&#x5C06;ack&#x8BBE;&#x7F6E;&#x4E3A;1&#xFF0C;seq&#x8BBE;&#x7F6E;&#x4E3A;1&#xFF0C;&#x5411;&#x670D;&#x52A1;&#x5668;&#x53D1;&#x9001;ACK&#x62A5;&#x6587;&#x6BB5;&#xFF0C;&#x8FD9;&#x4E2A;&#x62A5;&#x6587;&#x6BB5;&#x53D1;&#x9001;&#x5B8C;&#x6BD5;&#x4EE5;&#x540E;&#xFF0C;&#x5BA2;&#x6237;&#x7AEF;&#x548C;&#x670D;&#x52A1;&#x5668;&#x7AEF;&#x90FD;&#x8FDB;&#x5165;ESTABLISHED&#x72B6;&#x6001;&#xFF0C;&#x5B8C;&#x6210;TCP&#x4E09;&#x6B21;&#x63E1;&#x624B;&#x3002;<h2 id="t56. &#x6570;&#x636E;&#x4F20;&#x8F93;">6. &#x6570;&#x636E;&#x4F20;&#x8F93; <a href="#t56. &#x6570;&#x636E;&#x4F20;&#x8F93;"> # </a></h2>
<img src="http://img.zhufengpeixun.cn/datatransfer8.jpg" alt="handshake2"></li>
<li>&#x5BA2;&#x6237;&#x7AEF;&#x5148;&#x5411;&#x670D;&#x52A1;&#x5668;&#x53D1;&#x9001;&#x6570;&#x636E;&#xFF0C;&#x8BE5;&#x6570;&#x636E;&#x62A5;&#x662F;&#x957F;&#x5EA6;&#x4E3A;159&#x7684;&#x6570;&#x636E;&#x3002;</li>
<li>&#x670D;&#x52A1;&#x5668;&#x6536;&#x5230;&#x62A5;&#x6587;&#x540E;, &#x4E5F;&#x5411;&#x5BA2;&#x6237;&#x7AEF;&#x53D1;&#x9001;&#x4E86;&#x4E00;&#x4E2A;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x786E;&#x8BA4;&#xFF08;ACK&#xFF09;&#xFF0C;&#x5E76;&#x4E14;&#x8FD4;&#x56DE;&#x5BA2;&#x6237;&#x7AEF;&#x8981;&#x8BF7;&#x6C42;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x6570;&#x636E;&#x7684;&#x957F;&#x5EA6;&#x4E3A;111&#xFF0C;&#x5C06;seq&#x8BBE;&#x7F6E;&#x4E3A;1&#xFF0C;ack&#x8BBE;&#x7F6E;&#x4E3A;160&#xFF08;1 + 159&#xFF09;&#x3002;</li>
<li>&#x5BA2;&#x6237;&#x7AEF;&#x6536;&#x5230;&#x670D;&#x52A1;&#x5668;&#x8FD4;&#x56DE;&#x7684;&#x6570;&#x636E;&#x540E;&#x8FDB;&#x884C;&#x786E;&#x8BA4;&#xFF08;ACK&#xFF09;&#xFF0C;&#x5C06;seq&#x8BBE;&#x7F6E;&#x4E3A;160&#xFF0C; ack&#x8BBE;&#x7F6E;&#x4E3A;112&#xFF08;1 + 111&#xFF09;&#x3002;</li>
</ul>
<h2 id="t67. &#x56DB;&#x6B21;&#x6325;&#x624B;">7. &#x56DB;&#x6B21;&#x6325;&#x624B; <a href="#t67. &#x56DB;&#x6B21;&#x6325;&#x624B;"> # </a></h2>
<p><img src="http://img.zhufengpeixun.cn/goodbye8.jpg" alt="goodbye2"></p>
<ul>
<li>&#x7B2C;&#x4E00;&#x6B21;&#x6325;&#x624B;&#xFF1A;&#x5BA2;&#x6237;&#x7AEF;&#x5411;&#x670D;&#x52A1;&#x5668;&#x53D1;&#x9001;&#x4E00;&#x4E2A;FIN&#x62A5;&#x6587;&#x6BB5;&#xFF0C;&#x5C06;&#x8BBE;&#x7F6E;seq&#x4E3A;160&#x548C;ack&#x4E3A;112&#xFF0C;;&#x6B64;&#x65F6;&#xFF0C;&#x5BA2;&#x6237;&#x7AEF;&#x8FDB;&#x5165; FIN_WAIT_1&#x72B6;&#x6001;,&#x8FD9;&#x8868;&#x793A;&#x5BA2;&#x6237;&#x7AEF;&#x6CA1;&#x6709;&#x6570;&#x636E;&#x8981;&#x53D1;&#x9001;&#x670D;&#x52A1;&#x5668;&#x4E86;&#xFF0C;&#x8BF7;&#x6C42;&#x5173;&#x95ED;&#x8FDE;&#x63A5;;</li>
<li>&#x7B2C;&#x4E8C;&#x6B21;&#x6325;&#x624B;&#xFF1A;&#x670D;&#x52A1;&#x5668;&#x6536;&#x5230;&#x4E86;&#x5BA2;&#x6237;&#x7AEF;&#x53D1;&#x9001;&#x7684;FIN&#x62A5;&#x6587;&#x6BB5;&#xFF0C;&#x5411;&#x5BA2;&#x6237;&#x7AEF;&#x56DE;&#x4E00;&#x4E2A;ACK&#x62A5;&#x6587;&#x6BB5;&#xFF0C;ack&#x8BBE;&#x7F6E;&#x4E3A;1&#xFF0C;seq&#x8BBE;&#x7F6E;&#x4E3A;112;&#x670D;&#x52A1;&#x5668;&#x8FDB;&#x5165;&#x4E86;CLOSE_WAIT&#x72B6;&#x6001;&#xFF0C;&#x5BA2;&#x6237;&#x7AEF;&#x6536;&#x5230;&#x670D;&#x52A1;&#x5668;&#x8FD4;&#x56DE;&#x7684;ACK&#x62A5;&#x6587;&#x540E;&#xFF0C;&#x8FDB;&#x5165;FIN_WAIT_2&#x72B6;&#x6001;;</li>
<li>&#x7B2C;&#x4E09;&#x6B21;&#x6325;&#x624B;&#xFF1A;&#x670D;&#x52A1;&#x5668;&#x4F1A;&#x89C2;&#x5BDF;&#x81EA;&#x5DF1;&#x662F;&#x5426;&#x8FD8;&#x6709;&#x6570;&#x636E;&#x6CA1;&#x6709;&#x53D1;&#x9001;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#xFF0C;&#x5982;&#x679C;&#x6709;&#xFF0C;&#x5148;&#x628A;&#x6570;&#x636E;&#x53D1;&#x9001;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#xFF0C;&#x518D;&#x53D1;&#x9001;FIN&#x62A5;&#x6587;&#xFF1B;&#x5982;&#x679C;&#x6CA1;&#x6709;&#xFF0C;&#x90A3;&#x4E48;&#x670D;&#x52A1;&#x5668;&#x76F4;&#x63A5;&#x53D1;&#x9001;FIN&#x62A5;&#x6587;&#x7ED9;&#x5BA2;&#x6237;&#x7AEF;&#x3002;&#x8BF7;&#x6C42;&#x5173;&#x95ED;&#x8FDE;&#x63A5;&#xFF0C;&#x540C;&#x65F6;&#x670D;&#x52A1;&#x5668;&#x8FDB;&#x5165;LAST_ACK&#x72B6;&#x6001;;</li>
<li>&#x7B2C;&#x56DB;&#x6B21;&#x6325;&#x624B;&#xFF1A;&#x5BA2;&#x6237;&#x7AEF;&#x6536;&#x5230;&#x670D;&#x52A1;&#x5668;&#x53D1;&#x9001;&#x7684;FIN&#x62A5;&#x6587;&#x6BB5;&#xFF0C;&#x5411;&#x670D;&#x52A1;&#x5668;&#x53D1;&#x9001;ACK&#x62A5;&#x6587;&#x6BB5;&#xFF0C;&#x5C06;seq&#x8BBE;&#x7F6E;&#x4E3A;161&#xFF0C;&#x5C06;ack&#x8BBE;&#x7F6E;&#x4E3A;113&#xFF0C;&#x7136;&#x540E;&#x5BA2;&#x6237;&#x7AEF;&#x8FDB;&#x5165;TIME_WAIT&#x72B6;&#x6001;;&#x670D;&#x52A1;&#x5668;&#x6536;&#x5230;&#x5BA2;&#x6237;&#x7AEF;&#x7684;ACK&#x62A5;&#x6587;&#x6BB5;&#x4EE5;&#x540E;&#xFF0C;&#x5C31;&#x5173;&#x95ED;&#x8FDE;&#x63A5;;&#x6B64;&#x65F6;&#xFF0C;&#x5BA2;&#x6237;&#x7AEF;&#x7B49;&#x5F85;2MSL&#x540E;&#x4F9D;&#x7136;&#x6CA1;&#x6709;&#x6536;&#x5230;&#x56DE;&#x590D;&#xFF0C;&#x5219;&#x8BC1;&#x660E;Server&#x7AEF;&#x5DF2;&#x6B63;&#x5E38;&#x5173;&#x95ED;&#xFF0C;&#x5BA2;&#x6237;&#x7AEF;&#x4E5F;&#x53EF;&#x4EE5;&#x5173;&#x95ED;&#x8FDE;&#x63A5;&#x4E86;&#x3002;</li>
</ul>
<blockquote>
<p>&#x6CE8;&#x610F;&#xFF1A;&#x5728;&#x63E1;&#x624B;&#x548C;&#x6325;&#x624B;&#x65F6;&#x786E;&#x8BA4;&#x53F7;&#x5E94;&#x8BE5;&#x662F;&#x5BF9;&#x65B9;&#x5E8F;&#x5217;&#x53F7;&#x52A0;1,&#x4F20;&#x8F93;&#x6570;&#x636E;&#x65F6;&#x5219;&#x662F;&#x5BF9;&#x65B9;&#x5E8F;&#x5217;&#x53F7;&#x52A0;&#x4E0A;&#x5BF9;&#x65B9;&#x643A;&#x5E26;&#x5E94;&#x7528;&#x5C42;&#x6570;&#x636E;&#x7684;&#x957F;&#x5EA6;&#x3002;</p>
</blockquote>
<h2 id="t78. &#x95EE;&#x9898;">8. &#x95EE;&#x9898; <a href="#t78. &#x95EE;&#x9898;"> # </a></h2>
<ol>
<li>&#x4E3A;&#x4EC0;&#x4E48;&#x9700;&#x8981;&#x4E09;&#x6B21;&#x63E1;&#x624B;?
&#x786E;&#x4FDD;&#x53CC;&#x65B9;&#x6536;&#x53D1;&#x90FD;&#x662F;&#x6B63;&#x5E38;&#x7684;</li>
<li>&#x4E3A;&#x4EC0;&#x4E48;&#x9700;&#x8981;&#x56DB;&#x6B21;&#x6325;&#x624B;?
&#x53CC;&#x65B9;&#x6570;&#x636E;&#x53D1;&#x9001;&#x5B8C;&#x6BD5;&#xFF0C;&#x90FD;&#x8BA4;&#x4E3A;&#x53EF;&#x4EE5;&#x65AD;&#x5F00;</li>
<li>&#x4E3A;&#x4EC0;&#x4E48;&#x9700;&#x8981;&#x7B49;&#x5F85;?
A&#x5411;B&#x53D1;&#x7684;<code>FIN</code>&#x53EF;&#x80FD;&#x4E22;&#x5931;</li>
<li>&#x4E3A;&#x4EC0;&#x4E48;&#x63E1;&#x624B;&#x662F;&#x4E09;&#x6B21;&#xFF0C;&#x4F46;&#x6325;&#x624B;&#x5374;&#x662F;&#x56DB;&#x6B21;?
&#x5F53;Server&#x7AEF;&#x6536;&#x5230;FIN&#x62A5;&#x6587;&#x65F6;&#xFF0C;&#x5F88;&#x53EF;&#x80FD;&#x5E76;&#x4E0D;&#x4F1A;&#x7ACB;&#x5373;&#x5173;&#x95ED;SOCKET</li>
</ol>
<h2 id="t89.&#x540C;&#x5B66;&#x4EEC;&#x7684;&#x6587;&#x7AE0;">9.&#x540C;&#x5B66;&#x4EEC;&#x7684;&#x6587;&#x7AE0; <a href="#t89.&#x540C;&#x5B66;&#x4EEC;&#x7684;&#x6587;&#x7AE0;"> # </a></h2>
<ul>
<li><a href="https://gcystar.github.io/2018/02/06/core/tcp%E7%9A%84%E8%AE%A4%E7%9F%A5%E5%92%8C%E5%BA%94%E7%94%A8/">&#x9AD8;&#x6625;&#x9633;</a></li>
<li><a href="https://juejin.im/post/5a7c4ebaf265da4e81239431">whynotgonow</a></li>
<li><a href="https://juejin.im/post/5a7fea206fb9a06333151e99">&#x674E;&#x658C;</a></li>
</ul>

        <div class="copyright">Powered by <a href="https://github.com/jaywcjlove/idoc" target="_blank">idoc</a>. Dependence <a href="https://nodejs.org">Node.js</a> run.</div>
    </div>
    
</div>

<script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.js"></script>
<script>
$('.warpper .page-toc ul ul li a').on('click',function(){
  $('.warpper .page-toc ul ul li a').removeClass('my-active')
  $(this).addClass('my-active')
})
  // if (!$('.understand-me').length) {
  //   var bar = $(window).height() - $('.navbar ').height() - $('.page-toc').position().top;
  //   var count = bar / 26 / 2;
  //   var barHeight = $('.page-toc').outerHeight();
  //   $('.page-toc li').eq(0).children('a').addClass('red');
  //   var arr = [];
  //   $("h1,h2,h3,h4,h5,h6").each(function () {
  //     arr.push($(this).position().top);
  //   });
  //   var timer
  //   function dark() {
  //     clearTimeout(timer)
  //      timer = setTimeout(function () {
  //      var top = Math.abs($('.page-toc > ul').position().top);
  //      var cur = $('.content').scrollTop();
  //      for (var i = arr.length; i >= 0; i--) {
  //        if (arr[i] <= cur) {
  //          break;
  //        }
  //      }
  //      if (i === -1) {
  //        i = 0;
  //      }
  //      $('.page-toc li a').removeClass('red');
  //      $('.page-toc li').eq(i).children('a').addClass('red');
  //      let height = $('.page-toc li').eq(i).position().top-$('.page-toc').height(); // 如果当前的offset出去了 回到中间可好？
  //      $('.page-toc').scrollTop(height+$('.page-toc').height()/2);
  //    },200)
  //   }

  //   $('.content').on('scroll', dark);
  // }
</script>
<style>

    /* ::-webkit-scrollbar{width:14px;}
    ::-webkit-scrollbar-track{background-color:transparent;}
    ::-webkit-scrollbar-thumb{background-color:transparent;}
    ::-webkit-scrollbar-thumb:hover {background-color:transparent}
    ::-webkit-scrollbar-thumb:active {background-color:transparent} */

    .page-toc > ul .red {
        background: #f3f3f3;
        z-index: 1;
        border-left: 3px solid #009a61;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        color: #000
    }





</style>
</body>
</html>
